FAQ Work with WordPress
Administration
Can my posts have URL instead of /index.php?p=76?
See:
How long is the release cycle of WordPress?
A major release of WordPress happens every 6 months or so. Suggest and vote on ideas for future releases at the WordPress Extend Ideas site.
Also refer WordPress Versions for the chronologically listed versions of WordPress along with the Change Log information on new features and improvements in each version. There are the future releases and links to their respective milestones in the bug tracker.
How do I turn on Permalinks, and what do I do about the errors?
See:
What are Roles for and what permissions do different Roles have?
See:
Why can’t I delete the uncategorized Category?
Deleting a category does not delete the posts in that category. Instead, posts that were only assigned to the deleted category are set to the uncategorized category. Also, all Pages are assigned the uncategorized Category.
The uncategorized category cannot be deleted, however you can specify your default categories for posts on the Settings – Writing screen of the Administration Screens.
Why is there no Page Template option when writing or editing a Page?
If there is no Page Template option when writing or editing a Page it may because there is no template file with the proper structure. For the Page Template box to be available to assign to a Page there must be a least one template file in your theme that has a structure at the beginning of the template file that looks like this:
<?php
/*
Template Name: My Custom Page
*/
?>
Create a new PHP file with any name under the theme directory and put above codes into the file. You will see the Page Template box appears that includes “My Custom Page” option in the Page Edit Screen. For more detail about Custom Page Template, refer Page Templates.
How do I determine a Post, Page, Category, Tag, or User ID?
Sometimes it is necessary to know the ID of a particular Post, Page, Category, Tag, or User. To determine that ID, use one of these method:
- Look in your browser status bar for the ID:
- Visit the related list table screen in your Administration Screen. For instance in the case of Posts visit Posts->All Posts, for Pages visit Pages->All Pages, and for Categories visit Posts->Categories.
- Now hover your mouse over the ‘item’ you need the ID. In the case of Pages, hover over that particular Page’s title in the Title column and for Categories hover over the Categories Name in the Name column.
- Look at the status bar (at the bottom of your browser) and the you will find at the end of the line something like “post=123” or “tag_ID=67”. In these cases, 123 is the Page ID, and 67 is the Category ID.
Configuration
How can I change how the date and / or time is displayed?
See:
How can I control comments people make?
See:
What do the Discussion Options mean?
See:
How do I install plugins?
See:
Why are all the comments being moderated?
Go to the Settings > Discussion screen and make sure that Comment must be manually approved is unchecked. With that option selected, all comments are sent to the moderation queue to await approval. Make sure that Hold a comment in the queue if it contains x or more links. is not blank and contains a number higher than zero. If this value is blank or zero, all comments containing links will be moderated. If the option mentioned above is unchecked, the link moderation value is higher than zero, and you still have this problem, then upgrade the comment spam plugins you have installed. If this continues to be a problem, deactivate the comment spam plugins one by one to determine the culprit and contact the plugin author for help.
How do I disable comments?
First, uncheck Allow people to post comments on new articles on the Settings > Discussion screen. This will only disable comments on future posts. Next, to completely disable comments, you will have to edit each past post and uncheck Allow Comments from the Edit Post screen. Use Bulk Edit to disable multiple posts at once.
- In the Posts_Screen, check the checkbox in the Table’s title to select all Posts in a given table.
- From Bulk Actions box, select Edit and click Apply.
- In the Bulk Edit Screen, select Do not allow option from Comments box
- Click Update.
Alternatively, you could run below MySQL query from the command line on a shell account or using phpMyAdmin, or through a wp-cli wp db query
:
UPDATE wp_posts SET comment_status = 'closed';
If your goal is to permanently remove comments, then follow the next steps. This is the example of Twenty Fifteen theme customization.
- Create a Child Themes of Twenty Fifteen theme.
- Copy
twentyfifteen_entry_meta()
function from parent’sinc/template-tags.php
to child theme’sfunctions.php
. - Comment out the if block that contains
comments-link
.
function twentyfifteen_entry_meta() {
if ( is_sticky() && is_home() && ! is_paged() ) {
:
}
// if ( ! is_single() && ! post_password_required() && ( comments_open() || get_comments_number() ) ) {
// echo '';
// /* translators: %s: post title */
// comments_popup_link( sprintf( __( 'Leave a comment on %s', 'twentyfifteen' ), get_the_title() ) );
// echo '';
// }
}
It removes the number of comments or “Leave a comment” message from bottom of each post.
- Newly create
comments.php
under the Child Theme’s directory without any contents. It removes the comment area of exsiting posts. - Activate the Child Teheme.
How do I disable trackbacks and pingbacks?
First, uncheck Allow link notifications from other blogs (pingbacks and trackbacks) on new articles on the Settings > Discussion screen. This will only disable trackbacks and pingbacks on future posts. Next, to completely disable trackbacks and pingbacks, you will have to edit each past post and uncheck Allow trackbacks and pingbacks on this page from the Edit Post screen. Use Bulk Edit to disable multiple posts at once. See also above image.
- In the Posts_Screen, check the checkbox in the Table’s title to select all Posts in a given table.
- From Bulk Actions box, select Edit and click Apply.
- In the Bulk Edit Screen, select Do not allow option from Pings box.
- Click Update.
Alternatively, you could run this MySQL query from the command line on a shell account or using phpMyAdmin, or through a wp-cli wp db query
:
UPDATE wp_posts SET ping_status = 'closed';
How do I change the site admin name?
To change your Admin Name, in the Administration Screens, choose the Users->Your Profile menu. Make your changes there. However, you are not able to change the username from within the Administration screen. In order to do this you must directly edit the MySQL database, however this is not recommended as your username is not often seen by other users.
See:
How do I find the absolute path I need for uploading images?
- Open the below page from your Browser
http://(site URL)/wp-admin/options.php
- Refer
upload_url_path
option value. If the value is blank, then the directorywp-content/upload
is the default destination to save.
Which files do I change to alter the way my blog looks?
See:
How do I upload images?
See:
Can I change the “Error establishing database connection” message to something more descriptive?
Just simply create a file to reside at wp-content/db-error.php, and in that file put the message you want displayed to users when WordPress determines the database connection is not available. That file will be used in place of “Error establishing database connection” message. You could even use the db-error.php to redirect users elsewhere. Here’s an example for db-error.php:
<?php
<pre>echo '<h2> This site is currently experiencing a problem with the database server.</h2> Press your browser Reload button to try again!';
?>
Modifying
Can I change the Smilies?
See:
How do I edit files?
See:
What is The Loop?
See:
How can I change the URL-structure for my posts?
See:
How can I change URL-structure for my posts on a Windows server?
See:
How do I use WordPress Template Tags to change what is displayed on the blog?
See:
How do I get All links to open in a new window?
Put this inside the section of your Theme’s template header.php file:
<base target="_blank" />
See:
How can I add an image to my RSS feed?
See:
If I turn off comments, it says “Comments Off” on the weblog. so how do I remove that?
Depending on your theme, some other message of similar intent may be displayed. The specifics of how to remove this message is theme dependent. You should be able to find the offending text in your theme’s comments.php
file. If it’s displayed by a PHP function, comment out the function with slash-asterisks ‘/*
‘ and ‘*/
‘ (without quotes) on either end of the function:
<?php /* _e( 'Comments are closed.' , 'twentytwelve' ); */ ?>
If it’s simply HTML, comment out the enclosing HTML tags by adding ‘<!--<span> </span>
‘ and ‘<span> </span>-->
‘ (not including the quotes, note the space after the first and before the last comment symbols):
<!-- <p class="nocomments">Comments are closed. -->
If you decide later to restore the message, you can simply remove the comment symbols.
How do I change what is shown when I password protect a post?
Hook the filters ‘the_title
‘ and ‘the_password_form
‘. Your filter function is passed exactly what the filter names imply. Use the str_replace()
function to search out the offending text and replace it with your preference (or nothing).
Note the ‘the_title
‘ filter fires for every single title, not just password protected posts, so you need to use the existence of the post_password
property to know whether to apply the string replace function or not.
Some themes may also have additional locations where content needs to be canged. Next example works with Twenty Fifteen Theme.
add_filter('the_title', 'replace_protected', 10, 2);
function replace_protected( $title, $id ) {
$post = get_post( $id );
if ( ! empty( $post->post_password ) ) {
$title = str_replace('Protected:', 'Hidden:', $title);
}
return $title;
}
add_filter('the_password_form', 'replace_message');
function replace_message( $form ) {
return str_replace('This post is password protected. To view it please enter your password below:',
'Enter you password below to see the surprise:', $form);
}
How can I allow certain HTML tags in my comments?
Use a custom filter in your themes functions.php
or plugin:
add_filter('preprocess_comment','fa_allow_tags_in_comments');
function fa_allow_tags_in_comments($data) {
global $allowedtags;
$allowedtags['span'] = array('style'=>array());
$allowedtags['p'] = array();
return $data;
}
How can I add advanced search ability to WordPress?
See:
Posts
How do I upload an image and display it in a post?
See:
What is pingback?
See:
What is trackback?
See:
Where is the permalink to my post?
See:
Can I use desktop blogging software?
See:
Can I blog by email?
See:
Spam, Spammers, Comments
What can I do to stop comment spam?
See:
More Information on Comment Spam
See:
Importing and Exporting
How do I Import a WordPress WXR file when it says it is too large to import?
If a WordPress WXR file, an XML file exported from WordPress, is too large to import, there are several things you might try to overcome that limit.
- Edit php.ini‘. Some hosts may not allow this settings.
memory_limit = 300M
post_max_size = 200M
upload_max_filesize = 100M
max_execution_time = 600
- memory_limit: Maximum amount of memory in bytes that a PHP script is allowed to allocate.
Note: memory_limit should be larger than post_max_size, and post_max_size must be larger than upload_max_filesize.
- Edit .htaccess. Some hosts may not allow this settings.
php_value memory_limit 300M
php_value post_max_size 200M
php_value upload_max_filesize 100M
- Edit wp-config.php
define('WP_MEMORY_LIMIT', '64MB');
See also Increasing memory allocated to PHP.
- In multisite environment, configure following settings
- From Network Admin dashboard, select Settings > Network Settings and increase the values of ‘Site upload space’ and ‘Max upload file size’.
- From Network Admin dashboard, select Sites > All Sites and click Edit menu under your site. Click Settings tab and incease the value of ‘Site Upload Space Quota’ or leave it blank for network default
- GZip the file. On some hosting services, a gzipped file can be automatically expanded in the background, without WordPress ever knowing the difference. This can allow you to make the file small enough to be fit into the maximum upload size constraints.
- On Windows, use 7Zip to create a gz archive out of the WXR file.
- On Linux, use the gzip command line.
- Make sure that the resulting file has the file extension of “.gz” before uploading it, as this is often necessary.
- This is not guaranteed to work, as it highly depends on the hosting configuration. If this fails, then try another method instead.
- Break the WordPress WXR file into smaller pieces by separating the data between posts and pasting the header/footer into each file.
- Always have the header
<rss version="2.0"
xmlns:excerpt="https://wordpress.org/export/1.2/excerpt/"
xmlns:content="http://purl.org/rss/1.0/modules/content/"
xmlns:wfw="http://wellformedweb.org/CommentAPI/"
xmlns:dc="http://purl.org/dc/elements/1.1/"
xmlns:wp="https://wordpress.org/export/1.2/"
>
<channel>
including all info like category, tags, etc to just before the first
- Always have the footer
</channel>
</rss>
- In between, add the posts start with end with and check to see whether the XML file you’re creating is less than or equal to 2MB. You’ll get the hang of it.
- As always, before importing the new XML’s, backup the database of the blog you are importing the XML files to and might as well export XML file of that blog as well for good measure.
See:
WXR Splitter Utilities:
How do I import links (blogroll) from another WordPress blog?
See: